// house_pkg/pages/locate/index.ts
import QQMap from '../../../utils/qqmap'
Page({
  /**
   * 页面的初始数据
   */
  data: {
    points: [],
    address: '',
  },
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad() {
    this.getLocation()
  },
  async getLocation() {
    // 调用小程序 API 获取用户位置
    const { latitude, longitude } = await wx.getLocation()
    // console.log(latitude, longitude)
    this.getPoint(latitude, longitude)
  },

  async chooseLocation() {
    const { latitude, longitude } = await wx.chooseLocation()

    // 获取新的位置附近的小区
    this.getPoint(latitude, longitude)
  },

  getPoint(latitude, longitude) {
    // 显示加载状态
    wx.showLoading({ title: '加载中...' })

    QQMap.reverseGeocoder({
      location: `${latitude},${longitude}`,
      success: (res) => {
        // 更新数据
        this.setData({ address: res.result.address })
      },
    })

    QQMap.search({
      keyword: '住宅小区', // 搜索关键词
      location: `${latitude},${longitude}`, // 设置中心点坐标
      success: (res) => {
        console.log(res)
        const points = res.data.map(({ id, title, _distance }) => {
          return { id, title, _distance }
        })

        this.setData({ points })
      },
      fail: (err) => {
        wx.utils.messagePrompt(err)
      },
      complete: () => wx.hideLoading(),
    })
  },
})
